数据结构与算法

您所在的位置:网站首页 数据结构与算法 串 数据结构与算法

数据结构与算法

2024-07-10 12:30:50| 来源: 网络整理| 查看: 265

文章目录 1 串匹配概述 2 蛮力算法 2.1 蛮力算法版本A 2.2 蛮力算法版本B 2.3 蛮力算法测试 3 KMP算法 3.1 KMP主算法 3.2 构造next表 3.3 KMP算法测试程序 4 BM算法 4.1 BM主算法 4.2 坏字符策略与bc表 4.3 好后缀策略与gs表 4.4 BM算法测试 5 Karp-Rabin算法 6 Sunday算法 参考材料

1 串匹配概述

字符串匹配有多种形式,包括模式检测( pattern detection),模式定位(pattern location),模式计数(pattern counting),模式枚举(pattern enumration)。

2 蛮力算法

蛮力算法是最直接最直觉的方法,可以作为改进的基础。

2.1 蛮力算法版本A //brute-force-A.h #include int matchA( char* P, char* T ){ //串匹配算法(Brute-force-1) size_t n = strlen( T ), i = 0; size_t m = strlen( P ), j = 0; while ( j //不匹配则文本串回退,模式串复位 i -= j - 1; j = 0; } return i - j; } 2.2 蛮力算法版本B //brute-force-B.h #include int matchB( char* P, char* T ){ //串匹配算法(Brute-force-2) size_t n = strlen( T ), i = 0; size_t m = strlen( P ), j ; for( i = 0; i if( T[i + j] != P[j] ) break;//失配则右移再做一轮比对 } if( j >= m ) break; //找到匹配子串 } return i; } 2.3 蛮力算法测试

蛮力算法的测试程序如下,可见匹配成功时,版本A与版本B都会返回模式串在文本串中的位置。串匹配失败时,版本1返回大于n-m,版本2返回n-m+1。

/* * test program on string matching * author@Ripples * 20200807 */ #include "brute-force-A.h" #include "brute-force-B.h" #include using namespace std; int main(){ //初始化模式串与文本串 char P[] = "structure"; char Y[] = "alo"; char T[] =


【本文地址】

公司简介

联系我们

今日新闻


点击排行

实验室常用的仪器、试剂和
说到实验室常用到的东西,主要就分为仪器、试剂和耗
不用再找了,全球10大实验
01、赛默飞世尔科技(热电)Thermo Fisher Scientif
三代水柜的量产巅峰T-72坦
作者:寞寒最近,西边闹腾挺大,本来小寞以为忙完这
通风柜跟实验室通风系统有
说到通风柜跟实验室通风,不少人都纠结二者到底是不
集消毒杀菌、烘干收纳为一
厨房是家里细菌较多的地方,潮湿的环境、没有完全密
实验室设备之全钢实验台如
全钢实验台是实验室家具中较为重要的家具之一,很多

推荐新闻


图片新闻

实验室药品柜的特性有哪些
实验室药品柜是实验室家具的重要组成部分之一,主要
小学科学实验中有哪些教学
计算机 计算器 一般 打孔器 打气筒 仪器车 显微镜
实验室各种仪器原理动图讲
1.紫外分光光谱UV分析原理:吸收紫外光能量,引起分
高中化学常见仪器及实验装
1、可加热仪器:2、计量仪器:(1)仪器A的名称:量
微生物操作主要设备和器具
今天盘点一下微生物操作主要设备和器具,别嫌我啰嗦
浅谈通风柜使用基本常识
 众所周知,通风柜功能中最主要的就是排气功能。在

专题文章

    CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭